<template>
  <div>
    <p>
      <button @click="add()" class="btn btn-white btn-default btn-round">
        <i class="ace-icon fa fa-edit"></i>
        新增
      </button>
      &nbsp;
      <button @click="list(1)" class="btn btn-white btn-default btn-round">
        <i class="ace-icon fa fa-refresh"></i>
        刷新
      </button>
    </p>
    <pagination ref="pagination" v-bind:list="list"></pagination>
    <table id="simple-table" class="table  table-bordered table-hover">
      <thead>
      <tr>
<#list fieldList as field>
          <#if field.nameHump!="createdAt" && field.nameHump!="updatedAt">
        <th>${field.nameCn}</th>
          </#if>
        </#list>
        <th>操作</th>
      </tr>
      </thead>

      <tbody>
      <tr v-for="${domain} in ${domain}s">
        <#list fieldList as field>
          <#if field.nameHump!="createdAt" && field.nameHump!="updatedAt">
            <#if field.enums>
              <td>{{${field.enumsConst} | optionKV(${domain}.${field.nameHump})}}</td>
            <#else>
              <td>{{${domain}.${field.nameHump}}}</td>
            </#if>
          </#if>
        </#list>
        <td>
          <div class="hidden-sm hidden-xs btn-group">

            <button v-on:click="edit(${domain})" class="btn btn-xs btn-info">
              <i class="ace-icon fa fa-pencil bigger-120"></i>
            </button>

            <button v-on:click="del(${domain}.id)" class="btn btn-xs btn-danger">
              <i class="ace-icon fa fa-trash-o bigger-120"></i>
            </button>

          </div>
        </td>
      </tr>
      </tbody>
    </table>
    <div id="form-modal" class="modal fade" tabindex="-1" role="dialog">
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
            <h4 class="modal-title">表单</h4>
          </div>
          <div class="modal-body">
            <form class="form-horizontal">
              <#list fieldList as field>
                <#if field.nameHump!="id" && field.nameHump!="createdAt" && field.nameHump!="updatedAt">
                 <#if field.enums>
              <div class="form-group">
                <label class="col-sm-2 control-label">${field.nameCn}</label>
                <div class="col-sm-10">
                  <select v-model="${domain}.${field.nameHump}" class="form-control">
                    <option v-for="o in ${field.enumsConst}" v-bind:value="o.key">{{o.value}}</option>
                  </select>
                </div>
              </div>
                  <#else>
              <div class="form-group">
                <label class="col-sm-2 control-label">${field.nameCn}</label>
                <div class="col-sm-10">
                  <input v-model="${domain}.${field.nameHump}" class="form-control">
                </div>
              </div>
                  </#if>
                </#if>
              </#list>
            </form>
          </div>
          <div class="modal-footer">
            <button type="button" class="btn btn-default" data-dismiss="modal">取消</button>
            <button v-on:click="save()" type="button" class="btn btn-primary">保存</button>
          </div>
        </div><!-- /.modal-content -->
      </div><!-- /.modal-dialog -->
    </div><!-- /.modal -->
  </div>
</template>

<script>
import Pagination from "../../components/pagination.vue"
export default {
  components: {Pagination},
  name: "${module}-${domain}",
  data: function () {
    return {
      ${domain}: {},
      ${domain}s: [],
      <#list fieldList as field>
        <#if field.enums>
      ${field.enumsConst}: ${field.enumsConst},
        </#if>
      </#list>
    }
  },
  mounted: function () {
    let _this = this;
    _this.$refs.pagination.size = 5;
    _this.list(1);
    // sidebar激活样式方法一
    // this.$parent.activeSidebar("${module}-${domain}-sidebar")
  },
  methods: {
    /**
     * 点击【新增】
     */
    add() {
      let _this = this;
      _this.${domain} = {};
      $("#form-modal").modal("show");
    },
    /**
     * 点击【编辑】
     */
    edit(${domain}) {
      let _this = this;
      _this.${domain} = $.extend({}, ${domain});
      $("#form-modal").modal("show");
    },
    /**
     * 点击【保存】
     */
    save() {
      let _this = this;

      // 保存校验
      if (1 != 1
      <#list fieldList as field>
        <#if field.nameHump!="id" && field.nameHump!="createdAt" && field.nameHump!="updatedAt" && field.nameHump!="sort">
          <#if !field.nullAble>
        || !Validator.require(_this.${domain}.${field.nameHump}, "${field.nameCn}")
          </#if>
          <#if (field.length > 0)>
        || !Validator.length(_this.${domain}.${field.nameHump}, "${field.nameCn}", 1, ${field.length?c})
          </#if>
        </#if>
      </#list>
      ) {
        return;
      }

      Loading.show()
      _this.$ajax.post(process.env.VUE_APP_SERVER + '/${module}/admin/${domain}/save', _this.${domain}).then((response)=>{
        Loading.hide()
        // console.log("添加${tableNameCn}结果：",response)
        if (response.data.success) {
          $("#form-modal").modal("hide");
          _this.list(_this.$refs.pagination.page)
         if(_this.${domain}.id) {
           Toast.success("编辑成功！");
         }else {
           Toast.success("新增成功！");
         }
        }else {
          Toast.warning(response.data.message)
        }
      })
    },
    /**
     * 点击【删除】
     */
    del(id) {
      let _this = this;
      Confirm.show("删除后无法恢复当前数据",function () {
        Loading.show()
        _this.$ajax.delete(process.env.VUE_APP_SERVER + '/${module}/admin/${domain}/delete/' + id).then((response)=>{
          Loading.hide()
          // console.log("删除${tableNameCn}结果：",response)
          if (response.data.success) {
            _this.list(_this.$refs.pagination.page)
            Toast.success("删除成功！")
          }
        })
      })
    },
    /**
     * 列表查询
     */
    list(page) {
      let _this = this;
      Loading.show()
      _this.$ajax.post(process.env.VUE_APP_SERVER + '/${module}/admin/${domain}/list', {
        page: page,
        size: _this.$refs.pagination.size
      }).then((response)=>{
        Loading.hide()
        //console.log("查询${tableNameCn}列表结果：",response)
        _this.${domain}s = response.data.content.list
        _this.$refs.pagination.render(page, response.data.content.total)
      })
    }
  }
}
</script>

<style scoped>

</style>